草庐IT

database - 查询最后一天、上周、上个月 SQLite

全部标签

Ruby Date 1 个月前到 String

我需要在Ruby中计算从今天起1个月的日期,并将其转换为String格式:yyyy-dd-mmThh:MM:ss(e.g.2014-08-26T00:00:00)我试过:(DateTime.now-Date.today.prev_month).to_datetime.strftime("%FT%T")但我得到一个方法不存在的异常。 最佳答案 试试这个:require'date'd=Date.today.prev_month#orDate.today.next_month,dependingwhatyouwant=>#d.strfti

ruby-on-rails - 在设计注册中保留查询字符串

我正在使用railswithdevise进行注册。我还添加了一个邀请码,所以不是每个人都可以注册。邀请码通过“/users/sign_up?invite_code=wajdpapojapsd”之类的查询字符串传输,并使用“f.hidden_​​field:invite_code,:value=>params[”添加到注册表单的隐藏字段中:invite_code]".这很好用。唯一的问题是,如果注册没有得到验证和拒绝,设计重定向到“/users”并丢失带有invite_code的查询字符串。由于电子邮件在尝试失败后保留在注册表单中,我相信这也适用于邀请代码。作为最坏情况的解决方案,在注册

ruby-on-rails - 仅显示上周创建的帖子

我希望能够显示帖子并按几个标准对它们进行排序,首先是根据对它们的投票数量,其次是根据它们的创建日期。我不想显示超过一周的帖子,所以只显示上周的帖子。我试过这样做:但它给了我一个NilClass与2比较失败的错误我知道该代码仅通过按投票计数对帖子进行排序来工作,但我也想限制时间,所以有人可以告诉我如何做到这一点。我还是新手,很抱歉这么简单。 最佳答案 @Salil的解决方案没问题,但我建议添加counter_cache列(http://api.rubyonrails.org/classes/ActiveRecord/Associati

ruby-on-rails - 编写多行 ActiveRelation 查询的惯用方法是什么?

我的应用程序中有许多多行ActiveRelation查询方法,我不确定编写这些方法的最惯用方式。看看这个例子:defpostal_code_ids_within(miles)nearby_postal_codes=PostalCode.where("latitude>:min_latandlatitude:min_lonandlongitude我觉得有点不对劲。从中返回ActiveRelation对象的block似乎是惯用的,但我还没有看到这种方法。什么是标准? 最佳答案 根据Brian的建议,这更易读并且效果很好。scope:ne

ruby - 创建新数据库时 DataMapper SQLite 错误

我是Sinatra的新手,我正在尝试使用SQLite3和Datamapper创建一个数据库。我安装了gem和适配器,然后尝试在文件中执行此代码:#configrequire'sinatra'require'sinatra/contrib'ifdevelopment?require'data_mapper'DataMapper::setup(:default,"sqlite3://#{Dir.pwd}/recall.db")DataMapper.finalize.auto_upgrade!当我执行文件时,命令行给了我这个错误:C:/Ruby193/lib/ruby/site_ruby/1

ruby - Thor - 最后注入(inject)文件

我正在开发一个Rails引擎,我正在尝试编写一个生成器来放置这条线do_stuff(foo)作为config/routes.rb中的最后一条语句,不破坏文件语法。具体来说,如果我的config/routes.rb目前看起来像这样Rails.application.routes.drawdoblahmoreblahend运行生成器后,我希望config/routes.rb看起来像这样Rails.application.routes.drawdoblahmoreblahdo_stuff(foo)#injectedlineend我看了看什么ActiveAdmindoes,但无法创建一揽子最后

ruby - Rails 3 不会用 rvm 安装 sqlite3-ruby gem?

我正在试用rvm,并用它安装了ruby​​1.9.2和rails3。我需要重新安装sqlite3-rubygem(因为rvm为不同版本的ruby​​将所有gem分开)。问题是,当我尝试时,我得到:geminstallsqlite3-ruby/home/jenny/.rvm/rubies/ruby-1.9.2-p0/bin/gem:4:warning:Insecureworldwritabledir/home/jenny/.rvm/gems/ruby-1.9.2-p0/bininPATH,mode040777Buildingnativeextensions.Thiscouldtakeaw

ruby-on-rails - 如果评估的最后一个语句是 If 语句,Ruby 会返回什么

我的理解是ruby​​返回函数中评估的最后一条语句。如果函数以if语句结束,结果为falsedefthing(input)item=input=="hi"ifitem[]endendputsthing("hi").class#>Arrayputsthing("nothi").class#>NilClass我喜欢这个功能(如果语句为false,则返回nil),但为什么不返回false(从赋值给item)? 最佳答案 如果您的if语句没有运行任何代码,则返回nil,否则返回已运行代码的值。Irb是试验这些东西的好工具。irb(main)

ruby - 带有表双下划线的 Sequel gem 限定查询列名

使用Sequelgem:employees=DB[:prm_master__employee.identifier].join(:prm_master__employee_custom_fields.identifier,:employee=>:employee).where("termination_date>=?","06/01/2012").or("termination_date=NULL").and("employee='holderl'")以上失败:~/.rbenv/versions/1.9.3-p194/lib/ruby/gems/1.9.1/gems/sequel-3.

ruby-on-rails - ruby/rails 中的日期范围查询

我正在尝试运行以下查询。我知道语法有误,但我不太清楚它有什么问题。基本上,我试图找出有多少游戏的日期在今天的45天内。我有一个名为Game的模型,它有一个名为date_of_game的字段属性。我的查询:Game.where(date_of_game:谢谢!! 最佳答案 你说:howmanygameshavedatesthatarewithin45daysoftoday但是您的代码将检索日期小于今天+45天的所有游戏,这意味着它会返回去年的游戏。要遵循您的声明,您应该使用:Game.where(date_of_game:Date.c